草庐IT

Node.js开发、CommondJS 、ES-Module模块化设计

全部标签

ruby - 是否可以在 Ruby 模块中覆盖#initialize?

我一直在尝试弄清楚如何从模块扩展initialize的行为。我想在混入类的initialize中调用super的情况下执行此操作。我想支持调用include的正常模式我想不通。我已经阅读了我能找到的关于此事的所有内容,虽然人们提出了建议,但似乎没有一个真正有效(至少在我手中)。这是我(认为)我所知道的:如果完全可以做到,则必须使用include上的钩子(Hook)来完成(即Module.included(base))。includeHook将在包含类定义initialize之前执行,因此没有必要简单地尝试使用定义initializebase.instance_eval因为它将被覆盖。建

ruby-on-rails - Ruby on Rails,包括带参数的模块

有没有办法在包含ruby​​模块时使用参数?我有一个Assetable模块,它包含在许多类中。我希望能够即时生成attr_accessor。moduleAssetableextendActiveSupport::Concernincludeddo(argument).timesdo|i|attr_accessor"asset_#{i}".to_symattr_accessible"asset_#{i}".to_symendendend 最佳答案 有一个技巧:创建一个从模块继承的类,这样您就可以像类一样将任何参数传递给模块。class

ruby-on-rails - 如何在 Rails 应用程序中实现模块化?

Breakingalargerailsappintosmallerapps?ModularizingRailsapplicationsBestpracticeforstructuringa'large'Railsapp我有一个关于大型Rub​​yonRails应用程序模块化的快速问题。设置:我正在构建一个核心应用程序来存储有关人员的信息。我还有几个以非常不同的方式使用该信息的“模块”。(例如,一个可以显示有关人员的信息,另一个可以找出他们之间的联系和共同点,等等)。问题:如何有效地模块化此应用程序?可能的答案:由于模块与核心应用程序(以及彼此)共享模型和View,因此将它们组合到一个应

ruby-on-rails - 我应该忽略 schema.rb 因为扩展在开发/生产操作系统上不同吗?

我的数据库使用PostgreSQL。我在Mac上开发,需要这一行:#db/schema.rbonMacenvironmentenable_extension"plpgsql"但是,在Linux上不需要扩展。在这种情况下,我们是否应该忽略schema.rb并通过db:migrate为开发和生产环境生成它? 最佳答案 据我所知,问题是自动生成的schema.rb在生产和开发中会有所不同,因此会导致git中的文件发生变化,因为这一行。该行是由mac上的postgres适配器生成的吗?如果它是手动添加的,我会尝试将它放在其他地方,也许在初始

ruby - Rails:猴子修补 ActiveRecord::Base 与创建模块

我正在通读TheRails4way(由ObieFernandez撰写),一本关于Rails的著名书籍,从我目前阅读的内容来看,我强烈推荐它。但是,有一个示例部分9.2.7.1:MultipleCallbackMethodsinOneClass让我感到困惑:请耐心等待,为了让每个人都清楚问题,我在这个问题中复制了书中描述的步骤。该部分讨论了ActiveRecord回调(before_create、before_update等),并且可以创建一个类来为您处理多个回调。列出的代码如下:classAuditordefinitialize(audit_log)@audit_log=audit_l

ruby - MyModel 的副本已从模块树中删除但仍处于事件状态

每当我更改任何代码(View和一些Controller除外)时,我都会得到:AcopyofMyModelhasbeenremovedfromthemoduletreebutisstillactive!我必须重新启动我的开发服务器。我已经就此问题梳理了互联网,最常见的根本原因是从某个未自动加载的类调用MyModel.some_method。我在lib中有类似MyModel.find和MyModel.some_scope的类;但是,我已将Rails配置为自动加载lib树中的每个文件。我什至配置了所有内容的自动加载,包括app甚至config下任何位置的每个文件。一个可能相关的事实是MyMo

c - Ruby C 扩展开发人员的命名约定

在用C为ruby​​编写扩展时,我对遵循正确的命名约定很感兴趣。具体来说,我指的是将_p添加到谓词的函数名称以及为变量添加前缀m代表模块,c代表类等等。例如,如果我们想在C语言中定义一个像下面这样的谓词方法,我们应该在定义该方法的函数中使用_p作为后缀。classMyClassdefawesome?trueendend在C中:staticVALUEmy_extension_my_class_awesome_p(VALUEself){returnQtrue;}voidInit_my_extension(void){VALUEcMyClass=rb_define_class("MyClas

ruby - 在扩展自身的模块中的实例方法中调用单例方法

我自己扩展了Kernel,在实例方法Kernel#abort的定义中,我调用了单例方法Kernel.abort:moduleKernelextendselfdefabortputs"PressENTERtoexit..."getsKernel.abortendendabort当我调用Kernel#abort时,方法定义中的Kernel.abort调用似乎是指原始的Kernel#abort(扩展为Kernel.abort)。Ruby如何知道当我写Kernel.abort时,我指的是原始的abort方法,而不是我刚刚创建的方法?我将如何递归调用我刚刚创建的新abort方法?

ruby-on-rails - Ruby 2.0 如何在包含模块后从模块中取消包含模块?

moduleXendmoduleYendmoduleZ#TODOincludeXreplacementofincludingY#TODOincludeYreplacementofincludingXend有没有办法解决ruby​​不包含uninclude关键字的问题?? 最佳答案 如果您真的需要这种功能,您可以使用refinements来实现.classFooendmoduleXdefxputs'x'endendmoduleYendmoduleRrefineFoodoincludeXincludeYendend#Inaseparat

ruby-on-rails - 用于开发的本地 Gem 路径和用于生产的远程 Git repo

我有一个正在本地开发的gem,它被一个项目使用。如果我在中使用path指定gem的位置,我可以进行更改并且项目会选择新代码:gem'example',:path=>"~/path/to/gems/example"但是,当我推送到Heroku时,bundle失败,因为Heroku无法访问我本地计算机上的gem源。所以我可以将gem源推送到远程仓库并将gem源指向那里:gem'example',:github=>'example/example',:branch=>'example_feature'但是我现在需要将更改推送到这个repo,然后更新gem以在我的项目中获取新的更改:$cd~/